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Intellectual Property Rights 



IPRs essential or potentially essential to the present document may have been declared to ETSI. The information 
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found 
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in 
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web 
server ( http://ipr.etsi.org ). 

Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee 
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web 
server) which are, or may be, or may become, essential to the present document. 



Foreword 



This Technical Specification (TS) has been produced by ETSI Technical Committee Smart Card Platform (SCP). 

It is based on work originally done in the 3GPP in TSG-terminals WG3 and ETSI SMG. 

The contents of the present document are subject to continuing work within TC SCP and may change following formal 
TC SCP approval. If TC SCP modifies the contents of the present document, it will then be republished by ETSI with 
an identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

x the first digit: 

early working draft; 

1 presented to TC SCP for information; 

2 presented to TC SCP for approval; 

3 or greater indicates TC SCP approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

The present document specifies the structure of the Secured Packets in a general format. 

It is applicable to the exchange of secured packets between an entity in a network and an entity in the UICC. 

Secured Packets contain application messages to which certain mechanisms according to TS 102 224 [1] have been 
applied. Application messages are commands or data exchanged between an application resident in or behind the 
network and on the UICC. The Sending/Receiving Entity in the network and the UICC are responsible for applying the 
security mechanisms to the application messages and thus turning them into Secured Packets. 

2 References 

References are either specific (identified by date of publication and/or edition number or version number) or References 
are either specific (identified by date of publication and/or edition number or version number) or non-specific. For 
specific references, only the cited version applies. For non-specific references, the latest version of the reference 
document (including any amendments) applies. 

• In the case of a reference to a TC SCP document, a non specific reference implicitly refers to the latest version 
of that document in the same Release as the present document. 

Referenced documents which are not found to be publicly available in the expected location might be found at 
http://docbox.etsi.org/Reference . 

NOTE: While any hyperlinks included in this clause were valid at the time of publication ETSI cannot guarantee 
their long term validity. 

2.1 Normative references 

The following referenced documents are necessary for the application of the present document. 

[1] ETSI TS 102 224: "Smart Cards; Security mechanisms for UICC based Applications - Functional 

requirements". 

[2] Void. 

[3] ISO 16609 (2004): "Banking - Requirements for message authentication using symmetric 

techniques". 

[4] Void. 

[5] ETSI TS 13 1 1 15: "Universal Mobile Telecommunications System (UMTS); Secured packet 

structure for (Universal) Subscriber Identity Module (U)SIM Toolkit applications 
(3GPPTS 31.115)". 

[6] "GlobalPlatform Card Specification", version 2.2 including "Errata and precision list" 

Version 0.2. 

NOTE: See http://www.globalplatform.org/ . 

[7] "Applied Cryptography: Protocols, Algorithms, and Source Code in C", 2nd Edition, Bruce 

Schneier, John Wiley & Sons. 

[8] ETSI TS 101 220: "Smart cards; ETSI numbering system for telecommunication application 

providers". 

[9] ETSI TS 102 226: "Smart cards; Remote APDU structure for UICC based applications". 

[10] ETSI TS 102 127: "Smart cards; Transport protocol for CAT applications; Stage 2". 
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[11] ISO/IEC 13239 (2002): " Information technology - Telecommunications and information 

exchange between systems - High-level data link control (HDLC) procedures". 

[12] FIPS-197 (2001): "Advanced Encryption Standard (AES)". 

NOTE: See http://csrc.nist.gov/publications/fips/index.html . 

[13] NIST Special Publication 800-38A (2001): "Recommendation for Block Cipher Modes of 

Operation - Methods and Techniques". 

NOTE: See http://csrc.nist.gov/publications/nistpubs/ . 

[14] NIST Special Publication 800-38B (2005): "Recommendation for Block Cipher Modes of 

Operation: The CM AC Mode for Authentication". 

NOTE: See http://csrc.nist.gov/publications/nistpubs/ . 

[15] "GlobalPlatform Card UICC Configuration", Version 1.0. 

[16] ETSI TS 102 484: "Smart Cards; Secure channel between a UICC and an end-point terminal". 

[17] ETSI TS 102 483: "Smart Cards; UICC-Terminal interface; Internet Protocol connectivity between 

the UICC and terminal". 

2.2 Informative references 

The following referenced documents are not necessary for the application of the present document but they assist the 
user with regard to a particular subject area. 

Not applicable. 



Definitions and abbreviations 



3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply: 

Advanced Encryption Standard (AES): standard cryptographic algorithm specified in FIPS-197 [12] 

application layer: layer above the Transport Layer on which the Application Messages are exchanged between the 
sending and receiving applications 

application message: package of commands or data sent from the Sending Application to the Receiving Application, or 
vice versa, independently of the transport mechanism 

NOTE: An Application Message is transformed with respect to a chosen Transport Layer and chosen level of 
security into one or more secured packets. 

card manager: generic term for the 3 card management entities of a GlobalPlatform card i.e. the OPEN, Issuer Security 
Domain and the Cardholder Verification Method Services provider as defined in the GlobalPlatform Card 
Specification [6] 

command header: security header of a command packet 

NOTE: It includes all fields except the Secured Data. 

command packet: secured packet transmitted by the Sending Entity to the Receiving Entity, containing a secured 
Application Message 
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counter: mechanism or data field used for keeping track of a message sequence 

NOTE: This could be realized as a sequence oriented or time stamp derived value, maintaining a level of 
synchronization between the Sending Entity and the Receiving Entity. 

cryptographic checksum: string of bits derived from some secret information, (e.g. a secret key), part or all of the 
Application Message, and possible further information (e.g. part of the Security Header) 

NOTE: The secret key is known to the Sending Entity and to the Receiving Entity. The Cryptographic Checksum 
is often referred to as Message Authentication Code. 

Data Encryption Standard (DES): standard cryptographic algorithm specified as DEA in ISO 16609 [3] 

Data Encryption Key (DEK): key identifier for ciphering keys as defined in TS 102 226 [9] 

digital signature: string of bits derived from some secret information, (e.g. a secret key), the complete Application 
Message, and possible further information (e.g. part of the Security Header) 

NOTE: The secret information is known only to the Sending Entity. Although the authenticity of the Digital 

Signature can be proved by the Receiving Entity, the Receiving Entity is not able to reproduce the Digital 
Signature without knowledge of the secret information owned by the Sending Entity. 

issuer security domain: on-card entity providing support for the control, security, and communication requirements of 
the Card Issuer as defined in the GlobalPlatform Card Specification [6] 

receiving application: entity to which the Application Message is destined 

receiving entity: entity where the Secured Packet is received (e.g. SMS-SC, UICC, USSD entry point, or dedicated 
Toolkit Server) and where the security mechanisms are utilized 

NOTE: The Receiving Entity processes the Secured Packets. 

redundancy check: string of bits derived from the Application Message and possible further information for the 
purpose of detecting accidental changes to the message, without the use of any secret information 

response header: security header of a response packet 

response packet: secured packet transmitted by the Receiving Entity to the Sending Entity, containing a secured 
response and possibly application data 

secured data: this field contains the secured application message and possibly padding octets 

secured packet: information flow on top of which the level of required security has been applied 

NOTE: An Application Message is transformed with respect to a chosen Transport Layer and chosen level of 
security into one or more Secured Packets. 

security domain: on-card entity providing support for the control, security, and communication requirements of the 
Application Provider as defined in the GlobalPlatform Card Specification [6] 

security header: that part of the secured packet which consists of all security information (e.g. counter, key 
identification, indication of security level, checksum or Digital Signature) 

sender identification: simple verification of the identity of the Sending Entity by the Receiving Entity comparing the 
sender identity with an a priori stored identity of the sender at the Receiving Entity 

sending application: entity generating an Application Message to be sent 

sending entity: entity from which the Secured Packet originates (e.g. SMS-SC, UICC, USSD entry point, or dedicated 
Toolkit Server) and where the security mechanisms are invoked 

NOTE: The Sending Entity generates the Secured Packets to be sent. 

status code: indication that a message has been received (correctly or incorrectly, indicating reason for failure) 
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transport layer: layer responsible for transporting Secured Packets through the network 

NOTE: The transport layer implements one or more transport mechanisms, (e.g. SMS or USSD). 
unsecured acknowledgement: status code included in a response message 



3.2 



Abbreviations 



For the purpose of the present document, the following abbreviations apply: 

AES Advanced Encryption Standard 

API Application Programming Interface 

ARD Additional Response Data 

CBC Cipher Block Chaining 

CC Cryptographic Checksum 

CHI Command Header Identifier 

CHL Command Header Length 

CMAC Cipher-based Message Authentication Code 

CNTR CouNTeR 

CPI Command Packet Identifier 

CPL Command Packet Length 

CRC Cyclic Redundancy Check 

DEK Data Encryption Key 

DES Data Encryption Standard 

DS Digital Signature 

ISO International Organization for Standardization 

KIc Key and algorithm Identifier for ciphering 

KID Key and algorithm IDentifier for RC/CC/DS 

PCNTR Padding CouNTeR 

PoR Proof of Receipt 

RC Redundancy Check 

RE Receiving Entity 

RHI Response Header Identifier 

RHL Response Header Length 

RPI Response Packet Identifier 

RPL Response Packet Length 

RSC Response Status Code 

SE Sending Entity 

SMG Special Mobile Group 

SMS Short Message Service 

SMS-CB Short Message Service - Cell Broadcast 

SMS-SC Short Message Service - Service Centre 

SPI Security Parameters Indication 

TAR Toolkit Application Reference 

TLV Tag/Length/Value (data structure) 

USSD Unstructured Supplementary Services Data 
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Overview of security system 



An overview of the secure communication related to the Card Application Toolkit together with the required security 
mechanisms is given in TS 102 224 [1] (see figure 1). 
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Figure 1 : System overview 

The Sending Application prepares an Application Message and forwards it to the Sending Entity, with an indication of 
the security to be applied to the message. 

The Sending Entity prepends a Security Header (the Command Header) to the Application Message. It then applies the 
requested security to part of the Command Header and all of the Application Message, including any padding octets. 
The resulting structure is here referred to as the (Secured) Command Packet. 

Under normal circumstances the Receiving Entity receives the Command Packet and unpacks it according to the 
security parameters indicated in the Command Header. Additional security conditions may apply (e.g. a Minimum 
Security Level as defined in TS 102 226 [9]) before unpacking it. The Receiving Entity subsequently forwards the 
Application Message to the Receiving Application indicating to the Receiving Application the security that was applied. 
The interface between the Sending Application and Sending Entity and the interface between the Receiving Entity and 
Receiving Application are proprietary and therefore outside the scope of the present document. 

If so indicated in the Command Header, the Receiving Entity shall create a (Secured) Response Packet. The Response 
Packet consists of a Security Header (the Response Header) and optionally, application specific data supplied by the 
Receiving Application. Both the Response Header and the application specific data are secured using the security 
mechanisms indicated in the received Command Packet. The Response Packet will be returned to the Sending Entity, 
subject to constraints in the transport layer (e.g. timing). 

Although in some cases there might be no direct acknowledgement mechanism (i.e. for SMS-CB) the Sending 
Application may have requested a response. In this case a (Secured) Response Packet could be sent using a different 
bearer by the Receiving Application. 
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In some circumstances a security related error may be detected at the Receiving Entity. In such circumstances the 
Receiving Entity shall react according to the following rules: 

1) nothing shall be forwarded to the Receiving Application, i.e. no part of the Application Message, and no 
indication of the error; 

2) if the Sending Entity does not request a response (in the Command Header) the Receiving Entity discards the 
Command Packet and no further action is taken; 

3) if the Sending Entity does request a response and the Receiving Entity can unambiguously determine what has 
caused the error, the Receiving Entity shall create a Response Packet indicating the error cause. This Response 
Packet shall be secured according to the security indicated in the received Command Packet; 

4) if the Sending Entity does request a response and the Receiving Entity cannot determine what has caused the 
error, the Receiving Entity shall send a Response Packet indicating that an unidentified error has been 
detected. This Response Packet is sent without any security being applied; 

5) if the Receiving Entity receives an unrecognizable Command Header (e.g. an inconsistency in the Command 
Header), the Command Packet shall be discarded and no further action taken. 



5 Generalized secured packet structure 

Command and response packets have the same overall structure consisting of a variable length security header within a 
variable length shell. To model this, use is made of a double TLV -tag, length, value- structure. 

5.1 Command packet structure 

The Command Header precedes the Secured Data in the Command Packet, and is of variable length. 
The Command Packet shall be structured according to table 1 . 

Table 1 : Structure of the command packet 



Element 


Length 


Comment 


Command Packet Identifier (CPI) 


1 octet 


Identifies that this data block is the secured Command Packet. 


Command Packet Length (CPL) 


variable 


This shall indicate the number of octets from and including the 
Command Header Identifier to the end of the Secured Data, 
including any padding octets required for ciphering. 


Command Header Identifier (CHI) 


1 octet 


Identifies the Command Header. 


Command Header Length (CHL) 


variable 


This shall indicate the number of octets from and including the SPI 
to the end of the RC/CC/DS. 


Security Parameter Indicator (SPI) 


2 octets 


see detailed coding in clause 5.1 .1 . 


Ciphering Key Identifier (Klc) 


1 octet 


Key and algorithm Identifier for ciphering. 


Key Identifier (KID) 


1 octet 


Key and algorithm Identifier for RC/CC/DS. 


Toolkit Application Reference (TAR) 


3 octets 


Coding is application dependent as defined in TS 101 220 [8]. 


Counter (CNTR) 


5 octets 


Replay detection and Sequence Integrity counter. 


Padding Counter (PCNTR) 


1 octet 


This indicates the number of padding octets used for ciphering at 
the end of the secured data. 


Redundancy Check (RC), 
Cryptographic Checksum (CC) or 
Digital Signature (DS) 


variable 


Length depends on the algorithm. A typical value is 8 octets if 
used, and for a DS could be 48 or more octets; the minimum 
should be 4 octets. 


Secured data 


variable 


Contains the Secured Application Message and possibly padding 
octets used for ciphering. 



Unless indicated otherwise, the CPL and the CHL shall be coded according to BER-TV's coding of length in 
TS 101 220 [8]. 
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Table 2: Linear representation of command packet 



CPI 


CPL 


CHI 


CHL 


SPI 


Klc 


KID 


TAR 


CNTR 


PCNTR 


RC/CC/DS 


Secured 
data with 
padding 


















note 1 


note 1 


note 1 


note 1 


note 3 


note 3 


note 3 


note 3 


note 2 


note 2 


note 2 


note 2 


note 2 


note 2 




note 2 


NOTE 1 : These fields are included in the data to be ciphered if ciphering is indicated in the Security Header. 
NOTE 2: These fields are included in the calculation of the RC/CC/DS. 

NOTE 3: Part or all of these fields may also be included in the calculation of the RC/CC/DS, depending on 
implementation (e.g. SMS). 



If ciphering is indicated, first the RC/CC/DS shall be calculated as indicated in note 2 of table 2, and then ciphering 
shall be applied, as indicated in note 1 of table 2. 

If the SPI indicates that a specific field is unused, the Sending Entity shall set the contents of this field to zero, and the 
Receiving Entity shall ignore the contents. 

If the SPI indicates that no RC, CC or DS is present in the Command Header, the RC/CC/DS field shall be of zero 
length. 

Padding octets may consist of any plaintext value. If the Padding Counter content is zero, this shall indicate no padding 
octets, or no padding is necessary. 

5.1.1 Coding of the SPI 

The SPI is coded as below. 
First Octet: 



b8 b7 b6 b5 b4 B3 b2 bl 



00 
01 
10 

11 



No RC, CC or DS 
Redundancy Check 
Cryptographic Checksum 
Digital Signature 



: No Ciphering 

1 : Ciphering 

00: No counter available (note 1) 

01: Counter available; no replay or sequence 

checking (note 2) 
10: Process if and only if counter value is higher 

than the value in the RE (note 3) 
11: Process if and only if counter value is one 

higher than the value in the RE (note 4) 

Reserved (set to zero and ignored by RE) 



NOTE 1 : In this case the counter field is present in the message. 

NOTE 2: In this case the counter value is used for information purposes only, (e.g. date or time stamp). If the 

Command Packet was successfully unpacked, the counter value can be forwarded from the Receiving 

Entity to the Receiving Application. This depends on proprietary implementations and happens in an 

application dependent way. 
NOTE 3: The counter value is compared with the counter value of the last received Command Packet. This is 

tolerant to failures on the transport level (i.e. losses of Command Packets). A possible scenario is a global 

update. 
NOTE 4: This provides strict control in addition to security indicated in note 3. 
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Second Octet: 



B8 b7 b6 b5 b4 B3 b2 bl 



00 
01 
10 

11 

00 

01 
10 

11 



No PoR reply to the Sending Entity (SE) 

PoR required to be sent to the SE 

PoR required only when an error has occurred 

Reserved 

No RC, CC or DS applied to PoR response to SE 
PoR response with simple RC applied to it 
PoR response with CC applied to it 
PoR response with DS applied to it 



: PoR response shall not be ciphered 

1 : PoR response shall be ciphered 



Reserved for TS 31.115 [5] 

Reserved (set to zero and ignored by RE) 



If RC, CC or DS is applied to the Command Packet i.e. SPIl.b2bl is different from '00' and if RC, CC or DS is applied 
to the Response Packet i.e. SPI2.b4b3 is different from '00', then SPI2.b4b3 shall be set to the same value as SPIl.b2bl. 



5.1.2 Coding of the Klc 

The Klc is coded as below. 



B8 b7 b6 b5 b4 b3 b2 bl 



00: Algorithm known implicitly by both entities 

01: DES 

10: AES 

11: proprietary Implementations 

If b2 bl = 01 (DES) , b4 b3 shall be coded as 

follows : 

00: modeReserved for DES as defined in previous 
releases 

01: Triple DES in outer-CBC mode using two 
different keys 

10: Triple DES in outer-CBC mode using three 
different keys 

11: modeReserved for DES as defined in previous 
releases 

If b2 bl = 10 (AES) , b4 b3 shall be coded as 
follows : 

00: AES in CBC mode 

01, 10, 11: Reserved 



indication of Keys to be used 

(keys implicitly agreed between both entities) 



DES is the algorithm specified as DEA in ISO 16609 [3]. Triple DES in outer-CBC mode is described in clause 15.2 of 
[7]. 

The use of (single) DES is deprecated. However the coding is reserved for backwards compatibility with pre Release 8 
versions of this specification. 

AES is the block cipher algorithm specified in FIPS-197 [12]. AES in CBC mode is defined in NIST SP 800-38A [13]. 
The key length shall be known implicitly by both entities and shall be 128, 192 or 256 bits. 

The initial chaining value for CBC modes shall be zero. AES shall be used together with counter settings (b5 and b4 of 
the first octet of SPI) 10 or 1 1. 

For GlobalPlatform security architecture compliant cards see annex A. 
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5.1.3 Coding of the KID 



5.1 .3.1 Coding of the KID for Cryptographic Checksum 

If b2bl= '10' (Cryptographic Checksum) in the first byte of SPI, KID shall be coded as following: 



B8 b7 b6 b5 b4 b3 b2 bl 



00: Algorithm known implicitly by both entities 

01: DES 

10 : AES 

11: proprietary Implementations 

If b2 bl = 01 (DES) , b4 b3 shall be coded as 

follows : 

00: Reserved for DES as defined in previous 
releases 

01: Triple DES in outer-CBC mode using two 
different keys 

10: Triple DES in outer-CBC mode using three 
different keys 

11: Reserved 
If b2 bl = 10 (AES) , b4 b3 shall be coded as 
follows : 

00: AES in CMAC mode 

01, 10, 11: Reserved 

indication of Keys to be used 

(keys implicitly agreed between both entities) 



DES is the algorithm specified as DEA in ISO 16609 [3]. Triple DES in outer-CBC mode is described in clause 15.2 of 
[7]. 

In case of DES, the initial chaining value for CBC modes shall be zero. If padding is required, the padding octets shall 
be coded hexadecimal '00'. These octets shall not be included in the secured data. 

The use of (single) DES is deprecated. However the coding is reserved for backwards compatibility with pre Release 8 
versions of this specification. 

AES is the block cipher algorithm specified in FIPS-197 [12]. AES in CMAC mode is defined in 
NIST SP 800-38B [14]. The key length shall be known implicitly by both entities and shall be 128, 192 or 256 bits. 
AES shall be used together with counter settings (b5 and b4 of the first octet of SPI) 10 or 11. Each CMAC key shall be 
configured to accept and generate only cryptographic checksums with one length as defined in TS 102 226 [9] for PUT 
KEY for AES;; the length of the cryptographic checksum shall be 32 or 64 bits. 

For GlobalPlatform security architecture compliant cards see annex A. 



5.1 .3.2 Coding of the KID for Redundancy Check 

If b2bl= '01' (Redundancy Check) in the first byte of SPI, KID shall be coded as follows: 



b8 b7 b6 b5 b4 b3 b2 bl 



00 
01 
10 

11 



Algorithm known implicitly by both entities 

CRC 

Reserved 

proprietary Implementations 



If b2bl=01 (CRC), b4b3 shall be coded as follows: 

00: CRC 16 

01: CRC 32 

10 to 11: Reserved 

If b2bl = 10, b4 and b3 coding is reserved. 

For Proprietary use or 

For GlobalPlatform security architecture compliant 

cards: Key Version Number to be used. 



CRC algorithm is specified in ISO 13239 [11]. 

The generator polynomial used for CRC 16 shall be X A 16 + X A 12 + X A 5 + 1. 
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The generator polynomial used for CRC 32 shall be 

X A 32 + X A 26 + X A 23 + X A 22 + X A 16 + X A 12 + X A 11 + X A 10 + X A 8 + X A 7 + X A 5 + X A 4 + X A 2 + X + 1. 

The least significant bit of the first byte to be included in the checksum shall represent the most significant term of the 
input polynomial. 

The least significant term of the output polynomial shall represent the most significant bit of the first byte of the 
RC/CC/DS field. 

The initial value of the register shall be 'FFFF' for CRC 16 and FFFFFFFF' for CRC 32. 

The CRC result is obtained after an XOR operation of the final register value with FFFFFFFF' for CRC 32 or FFFF' for 
CRC 16. 

For GlobalPlatform security architecture compliant cards see annex A. 

5.1 .4 Counter Management 

If in the first SPI byte b4b5 = 00 (No counter available) the counter field shall be ignored by the RE and the RE shall 
not update the counter. 

If b5 of the first SPI byte is equal to 1 then the following rules shall apply to counter management, with the goal of 
preventing replay and synchronization attacks: 

• The SE sets the counter value. It shall only be incremented. 

• The RE shall update the counter to its next value upon receipt of a Command Packet after the corresponding 
security checks (i.e. RC/CC/DS and CNTR verification) have been passed successfully. 

• The next counter value is the one received in the incoming message. 

• When the counter value reaches its maximum value the counter is blocked. 

If there is more than one SE, care has to be taken to ensure that the counter values remain synchronized between the 
SEs to what the RE is expecting, irrespective of the transport mechanism employed. 

The level of security is indicated via the proprietary interface between the Sending/Receiving Application and 
Sending/Receiving Entity. Application designers should be aware that if the Sending Application requests "No 
RC/CC/DS" or "Redundancy Check" and "No Counter Available" from the SE, no security is applied to the Application 
Message and therefore there is an increased threat of malicious attack. 

For GlobalPlatform security architecture compliant cards see annex A. 
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5.2 Response Packet structure 



Table 3: Structure of the response packet 



Element 


Length 


Comment 


Response Packet Identifier (RPI) 


1 octet 


Identifies a Response Packet. 


Response Packet Length (RPL) 


variable 


Indicates the number of octets from and including RHI to the end of 
Additional Response data, including any padding octets. 


Response Header Identifier (RHI) 


1 octet 


Identifies the Response Header. 


Response Header Length (RHL) 


variable 


Indicates the number of octets from and including TAR to the end 
of the RC/CC/DS. 


Toolkit Application Reference (TAR) 


3 octets 


This shall be a copy of the contents of the TAR in the Command 
Packet. 


Counter (CNTR) 


5 octets 


This shall be a copy of the contents of the CNTR in the Command 
Packet. 


Padding counter (PCNTR) 


1 octet 


This indicates the number of padding octets at the end of the 
Additional Response Data. 


Response Status Code Octet 


1 octet 


Codings defined in table 5. 


Redundancy Check (RC), 
Cryptographic Checksum (CC) or 
Digital Signature (DS) 


variable 


Length depending on the algorithm indicated in the Command 
Header in the incoming message. A typical value is 4 octets to 
8 octets, or zero if no RC/CC/DS is requested. 


Additional Response Data 


variable 


Application Specific Response Data, including possible padding 
octets. The presence, length and coding of this field is defined by 
the application. This shall be empty for standardized response 
status codes different from "00". 



Unless indicated otherwise, the RPL and RHL shall be coded according to BER-TV's coding of length in 
TS 101 220 [8]. 



Table 4: Linear representation of response packet 



RPI 


RPL 


RHI 


RHL 


TAR 


CNTR 


PCNTR 


Status 
Code 


RC/CC/DS 


Additional 
response 
data with 
padding 












note 1 


note 1 


note 1 


note 1 


note 1 


note 3 


note 3 


note 3 


note 3 


note 2 


note 2 


note 2 


note 2 




note 2 


NOTE 1 : If ciphering is indicated in the Command Packet SPI then these fields shall be ciphered. 
NOTE 2: These fields shall be included in the calculation of the RC/CC/DS. 

NOTE 3: Part or all of these fields may also be included in the calculation of the RC/CC/DS, depending on 
implementation (e.g. SMS). 



If ciphering is indicated, first the RC/CC/DS shall be calculated as indicated in note 2 of table 4, and then ciphering 
shall be applied, as indicated in note 1 of table 4. 

If the SPI indicates that a specific field is unused, than its contents shall be set to zero, and ignored by the recipient of 
the Response Packet. 

If the SPI in the Command Packet indicates that no RC, CC or DS is present in the Command Header, this field shall be 
of zero length. 

Padding octets may consist of any plaintext value. If the Padding Counter content is zero, this shall indicate no padding 
octets are present, or no padding is necessary. 
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Table 5: Response status codes 



Status Code 
(hexadecimal) 


Meaning 


'00' 


PoR OK. 


'01' 


RC/CC/DS failed. 


'02' 


CNTR low. 


'03' 


CNTRhigh. 


'04' 


CNTR Blocked. 


'05' 


Ciphering error. 


'06' 


Unidentified security error. This code is for the case where the Receiving Entity cannot correctly 
interpret the Command Header and the Response Packet is sent unciphered with no RC/CC/DS. 


'07' 


Insufficient memory to process incoming message. 


'08' 


This status code "more time" should be used if the Receiving Entity/Application needs more time 
to process the Command Packet due to timing constraints. In this case a later Response Packet 
should be returned to the Sending Entity once processing has been completed. 


'09' 


TAR Unknown. 


'0A' 


Insufficient security level. 


'OB' 


Reserved for 3GPP (see TS 131 115 [5]). 


'0C 


Reserved for 3GPP (see TS 131 115 [5]). 


'0D' to 'BF' 


Reserved for future use. 


'CO' to 'FE' 


Reserved for proprietary use. 


'FF' 


Reserved for future use. 



Implementation for CAT_TP 



The generic secured Command Packet and secured Response Packet are contained in the CAT_TP Packet Data as 
defined in TS 102 127 [10]. 

In the Command Packet, the Command Packet Identifier (CPI) value is '01' and the Command Header Identifier (CHI) 
is a Null field. CPI, CPL and CHL shall be included in the calculation of the RC/CC/DS. 

In the Response Packet, the Response Packet Identifier (RPI) value is '02' and the Response Header Identifier (RHI) is a 
Null field. RPI, RPL and RHL shall be included in the calculation of the RC/CC/DS. 

Packet Identifier values '00' to 'BF' and 'FF' are reserved for use in the present document. Values 'CO' to FE' are 
reserved for proprietary implementations. 

The CAT_TP ports shall be used to address the applications running on top of CAT_TP, except when the CAT_TP link 
was opened by a PUSH command according to TS 102 226 [9] that was sent to the CAT_TP Multiplexing application 
identified by its TAR defined in TS 101 220 [8]. In that case, incoming packets on that CAT_TP link shall be forwarded 
by TAR addressing. 

The counter may be used also by an application to correlate Command Packets with Response Packets. 



Implementation for TCP/IP 



Before sending secured packets, the sending entity shall open a TCP/IP connection to the IP address and port of the 
receiving entity. The mechanisms to achieve this are detailed in TS 102 483 [17]. Optionally, this communication may 
be additionally secured using IPsec or TLS as detailed in TS 102 484 [16]. 

One or more generic secured command packets shall be transported from the sending entity as TCP application data. 
One or more generic secured response packets shall be transported from the receiving entity as TCP application data. 

In the Command Packet, the Command Packet Identifier (CPI) value is '01' and the Command Header Identifier (CHI) 
is a Null field. CPI, CPL and CHL shall be included in the calculation of the RC/CC/DS. 

In the Response Packet, the Response Packet Identifier (RPI) value is '02' and the Response Header Identifier (RHI) is a 
Null field. RPI, RPL and RHL shall be included in the calculation of the RC/CC/DS. 
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Packet Identifier values '00' to 'BF' and 'FF' are reserved for use in the present document. Values 'CO' to FE' are 
reserved for proprietary implementations. 

Incoming secured packets shall be forwarded to the applications based on the TAR. 

The counter may be used also by an application to correlate Command Packets with Response Packets. 
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Annex A (normative): 

Relation between security layer and GlobalPlatform security 

architecture 

This annex only applies to cards implementing the security architecture defined in the GlobalPlatform Card 
Specification [6]. 

At least one Security Domain shall be present on the card: the Issuer Security Domain. 

The security of Application Messages (i.e. RC/CC/DS, ciphering/deciphering, counter management) shall be managed 
by a Security Domain as specified in the UICC Configuration [15]. 

A.1 Key version - counter association within a Security 
Domain 

For each Security Domain, a dedicated counter shall be associated to each key version as described in table A.l. 

Table A.1 





Key Version Number 
'00' 


Key Version Number 
'01' 




Key Version 

Number n 

(maximum 'OF') 




Reserved 


Counter 1 




Counter n 


Key Identifier 1 


Reserved 


Kid 




Klcn 


Key Identifier 2 


Reserved 


KID 1 




KIDn 


Key Identifier 3 


Reserved 


DEK1 




DEKn 


NOTE 1 : The Key Version Number is defined in GlobalPlatform Card Specification [6]. The 

range from '01' to 'OF' is used in the present document. 
NOTE 2: The Key Identifier is defined in GlobalPlatform Card Specification [6]. The range from 

'01' to '03' is used in the present document. 



A.2 Security keys Klc, KID 



The indication of the key to be used in the Klc and KID fields shall refer to a GlobalPlatform key version number. 

The algorithm to be used with the key shall be the algorithm associated with the key (as described in the GlobalPlatform 
Card Specification [6] as detailed in the UICC Configuration [15]). 

The key version number indicated in the Klc and KID fields shall be identical when different from 0. If the key version 
numbers are different (and both different from 0) then the message shall be rejected with the "Unidentified security 
error" Response Status Code. 
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Annex B (informative): 
Example for CRC computation 

Example C code for calculating the CRC32: 

#include <stdio.h> 

typedef unsigned char byte; 

/* note that bit from the CRC and the polynomial is the MSB of the implementation */ 
void CRC32 (byte in[], int length, byte out [4] ) { 
unsigned long crc; 
int bit, byte, carry; 

crc = OxFFFFFFFF; /* initialization */ 
for (byte=0; byte<length; byte++) { 
for (bit=0; bit<8; bit++) { 
carry = crc & 1 ; 
crc >>=1; 
if (carry A ( (in [byte] >> bit) & 1)) 

crc *"= 0xedb88320 ; /*polynomial, bit X*32 is handled by the carry */ 



crc = -crc; /* invert CRC */ 
out [0] =crc>>24; 
out [1] =crc>>16 ; 
out [2] =crc>>8 ; 
out [3] =crc; 



int mainfint argc, char* argv[]) 

{ 

byte in [] ={1,2,3,4,5} ; 

byte c [4] ; 

CRC32(in, sizeof(in), c) ; 

printfC'crc = 0x%2 . 2X%2 . 2X%2 . 2X%2 . 2X\n" , c [0] , c [1] , c [2] , c [3] ) 

return ; 



EXAMPLE 1: If an input message is '01 02 03 04 05' where '01' is the first byte and '05' the last byte used for the 
computation, then the result of CRC 32 computation applied to the input message is 
47 0B 99 F4', where 47' would represent the first byte and 'F4' the last byte of the RC/CC/DS 
field. 

EXAMPLE 2: If an input message is '01 02 03 04 05' where '01' is the first byte and '05' the last byte used for the 
computation, then the result of CRC 16 computation applied to the input message is '22 EC, where 
'22' would represent the first byte and EC the last byte of the RC/CC/DS field. 
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Annex C (informative): 
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